-
Notifications
You must be signed in to change notification settings - Fork 2.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[v4.5 backport][CI:BUILD] Packit: add jobs for downstream Fedora package builds #18675
[v4.5 backport][CI:BUILD] Packit: add jobs for downstream Fedora package builds #18675
Conversation
Get rid of `podman.spec.rpkg` in favour of `rpm/podman.spec` which gets synced with fedora dist-git on every upstream release. The version in the new spec file is set to `0` by default and gets updated by packit automatically on every packit task. For local manual rpm builds using the spec, the helper script in the `rpm/` subdir will update the Version field with the latest version found in the upstream repo. Packit will automatically create a PR on fedora dist-git on every new upstream release. A sample PR will look like: https://src.fedoraproject.org/rpms/container-selinux/pull-request/10# A dry run for this can be triggered using: `$ packit propose-downstream --local-content` To run this command locally, you would need to have your packit user-configuration-file set. Ref: https://packit.dev/docs/configuration/#user-configuration-file along with a fedora api key created at: https://src.fedoraproject.org/settings#nav-api-tab with sufficient ACLs. Also includes a revised `package` Makefile target which will build rpms using `rpm/podman.spec`. Fixes: containers#18421. [NO NEW TESTS NEEDED] Signed-off-by: Lokesh Mandvekar <[email protected]> (cherry picked from commit 6003dca) Signed-off-by: Lokesh Mandvekar <[email protected]>
[APPROVALNOTIFIER] This PR is APPROVED This pull-request has been approved by: lsm5 The full list of commands accepted by this bot can be found here. The pull request process is described here
Needs approval from an approver in each of these files:
Approvers can indicate their approval by writing |
Signed-off-by: Lokesh Mandvekar <[email protected]>
@cevich you cool with disabling cirrus task for podman-next on maint branches ? (RE: second commit on this PR) |
actually, i don't see any reason to have cirrus task for podman-next on any branch. Correct me if i'm wrong. |
Yep...though I question why other stuff is being updated on a maintenance branch when (my understanding is) this only applies to the latest/greatest
You would know better than I. My (limited) understanding is the build (test and otherwise) are all handled by the Packit service, including for PRs, yes? If so, then, yep, feel free to nuke it everywhere. |
Also, I see Packit runs on this PR for F37/F38 but this release branch's CI is setup for F36/37. That seems like a recipe for future headaches. Can packit be blocked from running on other branches besides |
This is for the downstream Fedora tasks that will get triggered after an upstream release is published. The tasks need to be on the branch from which the release is cut. If you look at the
Yes, none of the rpm build tasks need to be done via cirrus. Thanks!
Packit CI is independent of Cirrus and directly uses the actively supported official Fedora branches. So what we specify in Cirrus doesn't matter to packit. The reason I asked about the cirrus task for podman-next was that it was failing on an earlier run on this PR, hence the additional commit to disable it. |
Yep I get that, what I was wondering about is the potential for drift. Imagine a CVE comes out and needs a patch made on this branch a year from now. Cirrus-CI will validate the fix against F36/37 then packet will try and build for F38/39. That build could fail if there's any incompatibility with any dependency. Is this concern real? Maybe is it possible to lock packit for this branch to only building F36/37 & Stream-8/9? |
Hmm, looks like I mixed up terminology earlier. This branch would be a release branch and not a maint branch. The So, the CVE concern would be real for |
Another thing to note about Copr infrastructure, copr follows Fedora's EOL policy. So, once fedora 36 goes EOL, the build env for f36 will vanish from copr. But anyway, any fedora release shouldn't be a concern for more than a year, CVE wise. Once v4.6 branch is created, we can stop caring about v4.5 branch for Fedora. |
Yeah, it's the Conceptually this SGTM (I haven't looked at any of the actual file changes). |
Great, thanks. Let me know if I should go ahead on any existing -rhel branches.
No worries. I subjected @edsantiago to that pain on the main branch already :D |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
A few minor bash-concerns for consideration.
LGTM pending @cevich's concerns |
Also address review concerns in pr#18675. [NO NEW TESTS NEEDED] Co-authored-by: Chris Evich <[email protected]> Signed-off-by: Lokesh Mandvekar <[email protected]>
a700d93
to
2b045de
Compare
@edsantiago @cevich addressed all concerns in a new commit here and I also have a PR with those changes at #18687 for the main branch . I uncommented a few lines in |
/lgtm |
LGTM |
Get rid of
podman.spec.rpkg
in favour ofrpm/podman.spec
which gets synced with fedora dist-git on every upstream release. The version in the new spec file is set to0
by default and gets updated by packit automatically on every packit task.For local manual rpm builds using the spec, the helper script in the
rpm/
subdir will update the Version field with the latest version found in the upstream repo.Packit will automatically create a PR on fedora dist-git on every new upstream release. A sample PR will look like:
https://src.fedoraproject.org/rpms/container-selinux/pull-request/10#
A dry run for this can be triggered using:
$ packit propose-downstream --local-content
To run this command locally, you would need to have your packit user-configuration-file set.
Ref: https://packit.dev/docs/configuration/#user-configuration-file
along with a fedora api key created at:
https://src.fedoraproject.org/settings#nav-api-tab with sufficient ACLs.
Also includes a revised
package
Makefile target which will build rpms usingrpm/podman.spec
. Fixes: #18421.[NO NEW TESTS NEEDED]
(cherry picked from commit 6003dca)
Does this PR introduce a user-facing change?